package com.czk.partition;

import org.apache.kafka.clients.producer.Partitioner;
import org.apache.kafka.common.Cluster;

import java.util.Map;

/**
 * @Author:ChenZhangKun
 * @Date: 2021/5/23 15:17
 */
public class MyPartitioner implements Partitioner {
    @Override
    public int partition(String topic, Object key, byte[] keyBytes, Object value, byte[] valueBytes, Cluster cluster) {
        System.out.println("执行自己的分区逻辑");
        // 拿到集群的分区数
        Integer partitionNum = cluster.partitionCountForTopic(topic);
        // 只有一个
        if (partitionNum == 1) return 0;

        if (keyBytes == null) {
            // 没有指定分区且，没有指定key时进入
            // 执行业务逻辑选择分区
            return 0;
        } else {
            return 0;
        }
    }

    @Override
    public void close() {

    }

    @Override
    public void configure(Map<String, ?> map) {

    }
}
